import Vue from 'vue'
import app from './App.vue'

//按需导入Mint-UI中的组件
/* import {Header,Swipe, SwipeItem,Button,Lazyload } from 'mint-ui'
Vue.component(Header.name,Header)
Vue.component(Swipe.name, Swipe)
Vue.component(SwipeItem.name, SwipeItem)
Vue.component(Button.name, Button)
Vue.use(Lazyload) */
import MintUI from 'mint-ui'
Vue.use(MintUI)
import 'mint-ui/lib/style.css'



//导入MUI样式
import './lib/mui/css/mui.min.css'
import './lib/mui/css/icons-extra.css'

//1.1导入路由的包
import VueRouter  from 'vue-router'
//1.2安装路由
Vue.use(VueRouter)

//注册vuex
import Vuex from 'vuex'
Vue.use(Vuex)

//每次刚进入网站，肯定会调用main.js，在刚调用的时候，先从本地存储把购物车的数据读取出来,放到store中
var cars = JSON.parse(localStorage.getItem('car') || '[]')

var store = new Vuex.Store({
	state:{	//this.$store.state.***
		
		//将购物车中的商品数据，用一个数组存储起来，在car数组中，存储一些商品的对象，咱们可以暂时将这个
		//商品对象，设计成这个样子 {id:商品id,count:要购买的数量,price:商品的单价,selected:false;}
		car : cars


	},
	mutations:{ //this.$store.commit('方法的名称','按需传递唯一的参数')
		
		addTocar(state,goodsinfo){
			 //点击加入购物车，把商品信息，保存到store中的car上
			 //分析
			 //1如果购物车中，之前就已经有这个对应的商品那么只需要修改数量

			 //假设购物车中，没有找到对应的商品
			var flag = false;

			state.car.some(item =>{
				if(item.id == goodsinfo.id){
					item.count += parseInt(goodsinfo.count)
					flag = true 
					return true
				}
			})
			//如果最终,循环完毕
			if(!flag){
				state.car.push(goodsinfo)
			}

			//当更新car之后，把car数组，存储到本地的localstorage中
			localStorage.setItem('car', JSON.stringify(state.car))
		},
		updateGoodsInfo(state,goodsinfo){
			//修改购物车中的商品数量值
			//分析
			state.car.some(item=>{
				if(item.id == goodsinfo.id){
					item.count = parseInt(goodsinfo.count)
					return true
				}
			})
			//当修改完商品的数量，把最新的购物车数据保存到本地存储中
			localStorage.setItem('car', JSON.stringify(state.car))

		},
		removeFormCar(state,id){
			//根据id从store中的购物车中删除对应的商品数据
			state.car.some((item,i)=>{
				if(item.id == id){
					state.car.splice(i,1)
					return true;
				}
			})
			//将删除完毕后的，最新的购物车数据，同步到本地储存中
			localStorage.setItem('car', JSON.stringify(state.car))
		},
		updateGoodsSelected(state,info){
			state.car.some(item=>{
				if(item.id == info.id){
					item.selected = info.selected
				}
			})
			//把最新的所有购物车商品的状态保存到store中去
			localStorage.setItem('car', JSON.stringify(state.car))
		}
	},
	getters:{	//this.$store.getters.**
		//相当于 计算属性，也相当于filters
		getAllCount(state){
			var c = 0;
			state.car.forEach(item=>{
				c += item.count
			})
			return c
		},
		getGoodsCount(state){
			var o = {}
			state.car.forEach(item=>{
				o[item.id] = item.count
			})
			return o
		},
		getGoodsSelected(state){
			var o ={}
			state.car.forEach(item=>{
				o[item.id] = item.selected
			})
			return o
		},
		getGoodsCountAndAmount(state){
			var o = {
				count:0, //勾选的数量
				amount:0	//勾选的总价
			}
			state.car.forEach(item=>{
				if(item.selected){
					o.count += item.count
					o.amount += item.price * item.count
				}
			})
			return o
		}

	}

})

//导入格式化时间插件
import moment from 'moment'
//定义全局过滤器
Vue.filter('dateFormat',function(dataStr,pattern="YYYY-MM-DD HH:mm:ss"){
	return moment(dataStr).format(pattern)
})

//2.1导入vue-resource
import VueResource from 'vue-resource'
//2.2安装vue-resource
Vue.use(VueResource)

//设置请求的更路径
Vue.http.options.root = 'http://127.0.0.1:8080/vue_cmsapi';
//全局设置post时候表单数据格式
Vue.http.options.emulateJSON =true;


//安装 图片预览插件
import VuePreview from 'vue-preview'
Vue.use(VuePreview)


//导入自己的router.js模块
import router from './router.js'

var vm = new Vue({
	el:'#app',
	render:c => c(app),
	router,  //挂载到vue实例上
	store //挂载store状态管理对象

})